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Abstract. Planarity Testing is the problem of determining whether a given graph is planar while 
planar embedding is the corresponding construction problem. The bounded space complexity of these 
problems has been determined to be exactly Logspace by AUender and Mahajan [AMOO with the aid 
of Reingold's result |IRei08j . Unfortunately, the algorithm is quite daunting and generalizing it to say, 
the bounded genus case seems a tall order. 

In this work, we present a simple planar embedding algorithm running in logspace. We hope this 
algorithm will be more amenable to generalization. The algorithm is based on the fact that 3-connected 
planar graphs have a unique embedding, a variant of Tutte's criterion on conflict graphs of cycles and 
an explicit change of cycle basis. 

We also present a logspace algorithm to find obstacles to planarity, viz. a Kuratowski minor, if the 
graph is non-planar. To the best of our knowledge this is the first logspace algorithm for this problem. 



1 Introduction 

Planarity Testing, the problem of determining whether a given graph is planar (i.e. the 
vertices and edges can be drawn on a plane with no edge intersections except at their end- 
points) is a fundamental problem in algorithmic graph theory. Along with the problem of 
actually obtaining a planar embedding, it is a prerequisite for many an algorithm designed 
to work specifically for planar graphs. 

Our focus is on the bounded space complexity of the planarity embedding problem be- 
cause we know that many graph theoretic problems like reachability |BTV09] , perfect match- 
ing jPKRlOfDKTlOj . and even isomorphism jDLN08|DLN"'"09] have efficient bounded space 
algorithms when provided graphs embedded on the plane. 

Almost a decade ago, building on previous work by Ramachandran and Reif |RR94j . 
AUender and Mahajan |AM00fAM04j . proved that Planarity Testing is contained in SL and 
is L-hard. With Reingold's result |Rei08] proving SL = L, this gave a tight complexity 
theoretic classification for the problem. This seemed to be the end of the story as far as the 
problem of Planarity Testing vis-a-vis the logspace world was concerned. 

The only catch was, the algorithm described in the paper was quite complicated - in 
fact a simpler SL algorithm was listed as one of the open questions in |AM00j . We would 
be satisfied with a complicate algorithm if all we were concerned with was pigeonholing the 
complexity of the problem. Planarity testing, however, happens to be a fundamental task 
in Topological Graph theory and a first step towards problems like toroidicity testing and 
bounded genus testing (also listed as open problems in |AM00j ). Therefore, if we are to make 
any progress towards a tighter classification of these problems, for which no efficient bounded 
space algorithm is known, especially, if making a non-blackbox use of a planarity algorithm, 
it is advisable to search for a less daunting algorithm. This work is the result of this search. 



In addition to its simplicity, the interplay between the properties of 3-connected planar 
graphs lends a certain elegance to the algorithm, at least in our, necessarily, biased eyes. 

We also give a logspace algorithm to identify a Kuratowski minor if the graph is non- 
planar. 

2 Related Work 

Here we survey the related work very briefly - see the paper by AUender and Mahajan |AMOO] 
for a detailed survey. The algorithmic aspects of Planarity Testing have been studied since the 
inception of Computer Science. It is clear that as far as sequential computation is concerned, 
a linear algorithm is optimal. Such algorithms include the one by Hopcroft and Tarjan 
|HT74j . The next result concerns parallel models of computation. Ramachandran and Reif 
proposed a very complicated algorithm which worked in logarithmic time and performed 
almost linar work and can be interpreted as placing the problem in the complexity class 
AC^. The final frontier was bounded space computation and initial sorties had already taken 
place in the early eighties. Reif |Rei84j proved that planarity testing for degree 3 graphs is 
in the SL-hierarchy while Ja'Ja' and Simon |JS82al)JS82b] proved that planarity testing is in 
the N L-hirerarchy. After Nisan and TaShma's result |NTS95] and the Immerman-Szelpcsenyi 
Theorem |Imm88|Sze88] these bounds become SL and NL respectively. The paper by AUender 
and Mahajan completed the campaign when they proved that Planarity Testing was SL- 
complete and Reingold's result |Rei08j set the final seal by proving SL = L. 

3 Outline of Algorithms 

3.1 Outline of Planar Embedding Algorithm 

We now motivate and informally describe Algorithm [T} It is easy to to see that for a planar 
graph G and any of its cycles, for the conflict graph w.r.t. the cycle is bipartite - the bipar- 
titions being given by the bridges that are placed inside the cycle and those that are placed 
outside it, in some planar embedding. 

Conversely, Tutte |Tut58j has shown that a graph is planar iff the conflict graph with 
respect to every cycle is bipartite. But since a graph potentially has exponentially many 
cycles a direct application of this result does not yield even a polynomial time algorithm. Thus 
we ought to seek a small set of cycles such that restricting our attention to the bipartiteness 
of their conflict graphs suffices to yield a planarity test. The set of fundamental cycles w.r.t. 
some spanning tree seems to be a natural candidate. Unfortunately, there are non-planar 
graphs which have a spanning tree such that the conflict graph w.r.t. each of the fundamental 
cycles is bipartite, e.g. in a with a spanning tree being a star centered at any vertex, the 
conflict graph w.r.t. any fundamental cycle has a single bridge. 

Suppose, however that we are able to flnd a deterministic algorithm that constructs a 
valid planar embedding whenever its input is planar graph and either fails when supplied with 
a non-planar graph or outputs a non-planar embedding. Now, since, its easy to check (via 
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verification of Euler's formula) that an embedding is planar, we can eliminate any non-planar 
graphs at this stage. 

Thus it suffices to focus on finding an embedding algorithm that works correctly under the 
promise that the given graph is planar. We can without much loss of generality, strengthen 
the promise and assume that the graph is, in addition to being planar, also 3-connected. This 
is because finding the triconnected components is known to be in logspace (see Lemma [l] and 
so is patching together the given planar embeddings of triconnected graphs (see Lemma [2]). 

Concentrating on 3-connected planar graphs we observe that: 



The graph has a unique planar embedding. 

The conflict graphs w.r.t. any cycle is connected (see Section 5.2), which enables us to 
bipartition the bridges in a unique way so that bridges in a partition lie on one side of 
the cycle in question. 

Ideally we would like to pick a small set of cycles and determine which edges lie inside 
them and somehow piece together the combinatorial embedding from this information. A 
natural choice for such a set is the set of fundamental cycles w.r.t. an arbitrary spanning 
tree. But the following two problems crop up: 

• Though we have a bipartition of bridges for each fundamental cycle , it is not clear 
which partition is mapped inside and which outside. 

• How do we actually piece together a combinatorial embedding once we know this 
information? 

The first problem can be solved if we knew at least one face of the unique embedding, 
because then we can just think of the face as the external face and stipulate that every 
edge (not part of the face) is contained inside it. Thus for every fundamental cycle, the 
bridge containing all the edges of the external face would lie outside the cycle - this fixes 
which bridges lie inside and which outside. But Corollary [T] tells us that for the graphs in 
question there is always a fundamental cycle which is a face. This, combined with Fact |2] 
ensures that we can find such a face in logspace. 



We solve the second problem in Section 5.4, where we first show that finding a solution 



is equivalent to a change of the cycle basis from fundamental cycles to faces. Then we 
show an explicit way to perform this inversion in logspace. 

Finally, we know that a 3-connected graph is planar iff every edge lies on exactly two 
induced non-separating cycles (see Fact|2]). Thus, we can use this criterion to check for 
planarity of G. 



3.2 Outline of Algorithm to find Kuratowski Minors 

In Section [6] we describe an algorithm (Algorithm [2]) to find a Kuratowski (i.e. a or K^^^) 
minor in a non-planar graph. The algorithm indentifies a cycle with a non-bipartite conflict 
graph. It then finds an induced odd cycle in this conflict graph. Finally, it contracts some of 
the bridges and vertices of attachment of these bridges to yield a Kuratowski minor. 
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4 Definitions and Preliminaries 



We assume familiarity with basic complexity theory in general and bounded space classes in 
particular, as described in any standard text e.g [AB09j . We will also assume familiarity with 
graph theory as described in a text like |Die05^Wes00j . Below, we explicate all non-standard 
material we will have occasion to use. 

Definition 1. The bridges of a cycle C consist of: 

— For every connected component X of G\C, the induced graph G[X U Ax] where Ax C C 
are the vertices of C adjacent to some vertex of X (the so called points of attachment) . 

— The chords of C - here the endpoints of C are its points of attachment 

Definition 2. Two bridges Bi, B2 of a cycle C conflict iff either of the following conditions 
hold: 

— ai,a'^ are two points of attachment of Bi w.r.t. C for i G {1,2} such that they occur in 
the order along the cycle C . 

— -81,-82 have three common points of attachment w.r.t. cycle C. 

We can extend the definition of conflict to sets of bridges Bi,B2 by the existence of two sets 
of conflicting vertices of attachment in the above sense, belonging to (not necessarily the 
same bridge of) Bi,B2 respectively. The conflict graph Hc{G) of a graph w.r.t. a cycle C 
is formed by taking the bridges of C as vertices and joining two vertices by an edge iff they 
conflict. 

Definition 3. Given a spanning tree T of a biconnected graph G, and an edge e G E{G) \ 
E{T), the graph GU e contains a unique cycle C(e) called the fundamental cycle of e. We 
say that a face of an embedded planar graph is fundamental if it is a fundamental cycle of 
some non-tree edge (with respect to some fixed spanning tree). 

The following is an easy consequence of Reingold's result |Rei08j since we can count the 
number of components in (G U e) \ e'. We single it out of a set of similar elementary graph 
computations summarized in Section 3.2 of |AM00j which can be done in logspace because 
it is of special significance for us. 

Fact 1 The list of edges in each fundamental cycle of G w.r.t. a spanning tree T can be 
obtained by a logspace transducer. 

Fact 2 (Proposition 4-2.10 and Theorem 4-5.2 jPieOSf ) The faces of a 3-connected planar 
graph G are exactly the induced non-separating cycles of G. Further, a 3-connected graph is 
planar iff every edge lies on exactly two induced, non-separating cycles. 

Proposition 1. Given a the cyclic order of vertices in every face of a biconnected embedded 
graph, it is possible to construct in logspace, a combinatorial embedding of the graph. 
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Proof. Call an ordered triplet, T of vertices {u,v,w) an angle of an embedded graph if 
{u,v), {v,w) are consecutive edges on some face of the embedding. Call two triplets Tj = 
{ui,Vi,Wi) for i G {1,2} adjacent if vi = V2 and either wi = U2 or ui = W2. Then it is clear 
that the undirected graph with angles as vertices and angle adjacencies as edges, forms a set 
of disjointj^ cycle^ The ordering on vertices induced by the angles is exactly the combina- 
torial embedding. □ 



5 Planar ity Testing 

5.1 Reduction to the Triconnected case 

Lemma 1. (Lemma 3.3 IDNTWOd^ ) The triconnected components of a graph can be ob- 
tained in logpace 

It is a well known fact that if a graph is non-planar then one of it's 3-connected components 
is non-planar. |WesOOj 

Lemma 2. Given a combinatorial planar embedding of the triconnected components of a 
graph, it is possible to obtain the biconnected planar embedding of the graph in logspace. 

Proof. Consider the tri-connected component , separating pair tree. This tree can be con- 
structed in logspace |DNTW09] . We will use the tree as an index to construct the embedding 
of the graph, given the embedding of it's 3 components. Given a vertex in a tri-connected 
component, we can obtain the clockwise order of the edges around the vertex using the given 
combinatorial embedding. 

Given a node in the tree corresponding to separating pair u, v we arrange the tri-connected 
components around u in the order they appear in the tree and around v in the opposite 
order. This gives us an ordering of edges around each vertex in the graph. We repeat this 
procedure for each of the nodes corresponding to a separating-pair in the tree. This gives 
us an embedding of the graph. To move from biconnected graphs to general graphs, see 
[AMOOj . □ 



5.2 The Conflict Graph 

Lemma 3. Given a 3-connected planar graph G and an arbitrary cycle C in the graph the 
conflict graph Hc{G) is bipartite and connected. 

Proof. It is easy to see that for an embedded planar graph G and any cycle G contained 
in it, the conflict graph, Hc{G) is bipartite (with the bipartition being given by whether a 
bridge is mapped "inside" or "outside" the cycle). We now show that Hc{G) is connected. 

For every pair of points x,y & G there are two paths from x to y along C. We will call 
these paths P^^y and P^ y. Let B he a. set of bridges that correspond to one of the connected 
components of HciG). 

Pick a pair m, v s.t 

^ since any angle has a unique middle vertex 

^ since every angle is adjacent to exactly two angles on a vertex 
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— u and V are attachment points of bridges in B. 

— u and V are not adjacent. 

— The attachment points of all bridges in B lie in either Pu^v or P^^,. (Assume WLOG that 
they lie in Pu,v)- 

We now show that one can always find such a pair v. Pick a bridge B' ^ B . The attachment 
points of B' divide C into a number of segments .(atleast 3 since every bridge has 3 or more 
points of attachment.) Since no bridge in B conflicts with B' and the vertices corresponding 
to B in Hc{G) form a connected component, it follows easily that all points of attachments 
of B must lie in one of the segments. This implies that there is a point in C(a point of 
attachment of B') that is not a point of attachment of any bridge in B. Therefore we can 
find a pair u, v with the properties listed above. 

Now, for every point x ^ {u,v} on Pu,v, 3 a bridge B E B with points of attachment 
61,62 s.t bi precedes x and 62 succeeds x in P^^,. If not then WB G B either all points of 
attachment of B lie between u and x or all of them lie between x and v. This implies that in 
Hc{G) vertices corresponding to bridges in u as a point of attachment are not connected 
to vertices corresponding to bridges with f as a point of attachment. This is a contradiction 
since B corresponds to a connected component in Hc{G). 

Now, if {m, f } is not a separating pair then 3 a bridge B ^ B with points of attachment 
in both Pu^v \ {u,v} and Pu^v \ {u,v}. From the above it follows that B' conflicts with a 
bridge in B which is not possible. Therefore, {u,v} is a separating pair. □ 



5.3 Inside and Outside a Fundamental Cycle 

Next we fix which bridges w.r.t. each of the fundamental cycles are mapped inside and which 
are mapped outside the concerned cycle. Basically we find one face of the grap and call it 
the external face. Thus every bridge containing this face is mapped outside any other cycle. 
This completely fixes the 2-coloring. 

Proposition 2. Any biconnected embedded planar graph has a fundamental face (i.e. a fun- 
damental cycle which is also a face) w.r.t. each of its spanning trees. 

Proof. It is well known that the set of dual edges of the non-tree edges of a biconnected 
planar graph forms a tree (after reducing all multi-edges to a single edge) - the so called 
dual tree. This follows from observing that cycles in the primal correspond to cuts in the 
dual (Proposition 4.6.1 |Die05j ) and therefore the set of edges dual to the non-tree edges are 
connected in the dual graph, the proof being completed by applying Euler's relation to verify 
that the number of such edges is exactly one less than the number of faces. It is easy to see 
that the face of the original graph corresponding to a leaf of the dual tree is a fundamental 
face. □ 

A direct consequence of Fact[T| Proposition |2| Fact [2] is the following (since finding whether 
a cycle is induced and non-separating is a logspace predicate given the list of edges in the 
cycle on the input tape). 
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Corollary 1. Every 3-connected planar graph has at least one fundamental face and this 
can be found by a Logspace transducer. 

Knowing which edges of the graph map to the region enclosed by each of the fundamental 
cycles, we proceed to construct a purported embedding of the given graph. If the graph is 
indeed planar we will obtain a valid planar embedding, else we will not be able to do so, 
giving an effective planarity test (which produces an embedding as a side-effect). 

5.4 Obtaining a Planar Embedding 

Here we exhibit a way to identify the edges in each face of the given 3-connected graph. 
Fact [2] then gives a way of effectively checking if the graph is plnar. 

At the heart of the proof is a change of basis in the cycle space over Z2 Somewhat 
msurprisingly the solution to the equations obtained in the previous section tell us which 
faces sum up (over Z2) to give a particular fundamental cycle. Notice that we have only an 
"implicit" representation of the faces (see below) and while we are seeking for an explicit 
representation in terms of which edges constitute a face. Since fundamental cycles and in- 
ternal faces both form a basis of the cycle space over Z2, we just need to invert the matrix 
that expresses the fundamental cycles as a linear combination of faces. Though seemingly 
this would place the problem in ©L we give an explicit way to perform this inversion which 
yields a L upper bound. 

Returning to the "implicit" representation of faces, there is a natural bijection between 
non-tree edges and faces viz. one that maps a non-tree edge e to that face /(e) adjacent to 
e which lies inside the fundamental cycle C(e) (w.r.t. the external face C(eo)). With faces 
labeled in this way, the solution of the preceding section tells us which faces are contained 
within the fundamental cycle C(e). 

Let us start by fixing some notation. For distinct non-tree edges 61,62, define 61 -< 62 
iff in a 2-coloring of the conflict graph Hc(e2){G), the colors of the vertices corresponding 
to bridges containing 60, 61 get different colors. Intuitively, this means that (if G is planar) 
C(62) separates 61 from cq in the unique planar embedding of G. 

For each e G E{G) \ {eo}, let P{e) denote: 

{e' G E{G) \ {E{T) U {6})|6' ^ e A $e" : e' ^ e" ^ e}, 
Further, let F{e) denote 

© Cie') 

e'eP(e)U{e} 

Notice that for sets A, B the set A® B denotes the symmetric difference of the two sets and 
the notation above refers to an iteration of this operation. 

If the graph is 3-connected planar then in its unique planar embedding with C(6o) as the 
external face, P{e) consists of the set of non-tree edges that are enclosed by e but not by 
any e" which is also enclosed by e. Intuitively, it clear that these are exactly the non-tree 
edges occurring on the face f{e) (see description in the preceding paragraph). We will make 
this intuition precise and in fact, show the following: 
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Lemma 4. For each non-tree edge e ^ Cq, the face /(e) consists exactly of the edges in the 
set F{e). 

Proof. Given a fundamental cycle C let 0(C) represent the number of faces that lie inside 
C and ip{C) represent the number of fundamental cycles that lie inside C including C. 
Notice that for fundamental cycles which are also faces, 0(C) = ip{C) = 1. In fact for every 
fundamental cycle C, as an easy consequence of Euler's formula it follows that 0(C) = ip{C). 

Let e G E{G) \ E(T). We will first show that F{e) is a face. Since each e' G P(e) lies 
inside C(e) and for every non-tree e" ^ -P(e), such that e" -< e, there is exactly one e' G P{e) 
such that e" -< e'. There is one such e' because we know that every non-tree edge enclosed 
by C(e) is either enclosed by some other fundamental cycle C(ei) or otherwise is in P{e). 
Thus by induction on the "enclosure depth" of an edge we get an e' G P{e) which encloses 
it. The uniqueness follows from observing that if both e -< e' A e -< e'^ then either e[ -< e! or 
e' -< e'^. - this is due to planarity - therefore both e', e!^ cannot be in P{e). Thus we get, 

^(C^(e)) = l+ E ^(C'(e')) 

e'eP(e) 

therefore: 

0(C(e)) = 1 + E 

e'6P(e) 

Now since every fundamental cycle can be written as a sum of internal faces of G and F[e) 
is a sum of a set of fundamental cycles (where all computation is over Z2), it is also a sum 
of some internal faces. Since only faces contained within C(e) figure in this sum, F[e) must 
be a disjoint sum of some cycles enclosed by C(e). We can be more specific, the sum: 

e'eP(e) 

includes exactly the faces inside C(e) which are also faces inside some C(e') for e' G -P(e). 
Thus F{e) includes exactly the faces contained inside C(e) but not in any C(e') for e' G -P(e). 
Now, it is easy to see from the expression for 0(C(e)) that there is exactly one such face, so 
it follows from the linear independence of the faces that this must be /(e). □ 

Thus, we can complete the proof of the following: 

Theorem 1. Given a graph G, constructing a planar embedding for G if it is planar and 
otherwise rejecting it, can be done in logspace. 

Proof. Given a graph we obtain its 3-connected components using Lemma [Tj If each tri- 
connected compoenent is planar, we will successfully obtain a planar embedding for each 
component and then obtain the proof with the aid of Lemma |2} If some triconnected com- 
ponent is not planar, we will either obtain an -F(e) which is not induced or is separating or 
we will obtain an edge lying on at least three -F(e)'s and therefore reject. 
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Input : Graph G 
Promise : G is 3-connected 

Output : A planar embedding of G if planar and otherwise 

1 Compute a spanning tree T in G; 

2 if there is no fundamental face w.r.t. T then return 0; 

3 Let Co = C(eo) be a fundamental face; 

4 foreach fundamental cycle C(e) 7^ Co do 

5 Construct conflict graph Hc{e){G)', 

6 if Hc(e){G) is not bipartite then return 0; 
T 2-co\or He (e){G); 

foreach non-tree edge e' 7^ e do 

// Let -Be'.e be the bridge of C(e) containing e' 
if -Be'.e <?ei.' color different from -Beo.e Hc(e)(G) then let e' -< e; 

end 



9 

10 

11 end 

12 foreach fundamental cycle C(e) 7^ Co do 

13 
14 



Let P(e) = {e' € S(G) \ (£;(T) U {e})|e' -< e A ^e" : e' ^ e" ^ e}; 
Let F(e)=e,,eP{e)u{e} C^(e'); 

15 end 

16 Let F(eo) = Co; 

17 foreach erfge e G E{G) do 

18 I if e doesn't lie in exactly two F{e') 's then return 0; 

19 end 

// Follow the proof of Proposition [l] to construct an embedding of G 

20 return planar embedding of G; 



Algorithm 1: Planarity Testing and Embedding Algorithm for 3-connected graphs 



6 Finding Kuratowski Subgraphs 

We describe an an algorithm to obtain a Kuratowski subgraph given a cycle with a non- 
bipartite conflict graph. As a consequence, to obtain a Kuratowski subgraph, it is sufficient 
to find such a cycle in a subgraph G' of G. We do this in a series of lemmas: 

Lemma 5. Given a non-planar graph G, we can, in logspace, find a non-planar subgraph G' 
and a cycle G G' s.t. Hc{G') is non-bipartite. 

Proof. Given access to a routine for planarity checking, and a non-planar graph G, we can 
find a minimal non- planar subgraph G' of g in the following sense. Order the edges of G 
arbitrarily as Ci, . . . , e^- Now consider the smallest i such that the graph G' formed by the 
union of the first i edges ei, . . . ,ej is non-planar. Notice that this means that G' \ is 
necessarily planar. 

Now, we show how one can find a cycle in this graph G' such that the conflict graph 
Hc{G') is non-bipartite. Construct a planar embedding of G' \ {e}. The endpoints, say x,y, 
of Ci must lie on different faces of this embedding because G' is non-planar. 

Find a path in the dual graph of the embedding between any two faces F^^Fy incident 
respectively on x, (this path must avoid any other faces incident on x or y.) The symmetric 
difference of the faces in this path is a cycle G one of whose bridges is Cj. 

We claim that HciG') is non-bipartite. If it were bipartite then it would be possible to give 
an orientation to each of it's bridges such that conflicting bridges got opposing orientations. 
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Input : Graph G 
Promise : G is non-planar 
Output : A Kuratowski Minor 

1 Find a non-planar subgraph G' and a cycle C C.G' s.t. Hc{G') is non-planar ; 

2 begin 

3 Fix an ordering of edges of G ; 

4 Find smallest edge ei = (a:, y) such that graph G' on {ei, . . . , e,} is non-planar; 

5 Find planar embedding of G' \ e,; 

6 Let Fx,Fy be two faces containing x, y respectively; 

7 Find a simple path between Fx,Fy in dual{G') which avoids all other faces containing x,y; 

8 Let C be the symmetric difference of the faces along this path; 
// Hc{G') is non-bipeirtite 

9 end 

10 Find an induced odd cycle C in Hc{G'); 

11 begin 

12 Find a spanning tree of Hc{G') and 2-color it; 

13 Pick a non-tree edge e with both endpoints of same color, so that all the chords of fundamental cycle 
C(e) have different colors; 

14 Walk on the tree between endpoints of e and "short-circuit" as many tree-paths, by chords, as possible; 

15 end 

16 Find a cycle with 3 mutually conflicting bridges; 

17 Contract the bridges to single vertices (if they originally contained a vertex) or edges; 

18 Find a Kuratowski minor of this graph by brute force; 

19 Expand back to a Kuratowski minor of the original graph; 

Algorithm 2: Algorithm for finding Kuratowski Minors 



But since the bridges of C are all planar, this would imply that G' is planar . Therefore, 
Hc{G') is non-bipartite. 

Lemma 6. Given a non-planar graph G' and a cycle G witnessing this via the non-bipartiteness 
of Hc{G'), we can, in logspace, find an induced odd cycle C in HciG'). 

Proof. Since the conflict graph Hc{G') is non-bipartite, it contains an odd cycle. Wc aim to 
find an induced odd cycle in this graph. For this consider a spanning tree of Hc{G'). 2-color 
the spanning tree. Notice that there must exist a non-tree edge between two vertices with 
the same color (else the graph would have been bipartite) . Find a non-tree edge e such that 
all the chords of the fundamental cycle C(e) get opposite colors - a simple induction on the 
number of chords that a fundamental cycle has, shows that such an edge must exist and 
locating it in logspace is easy. 

We will construct a chordless cycle from C(e) by replacing some tree paths by chords 
of C(e). To do this, let e = {ui,Uk) and let the vertices of the tree path from ui to Uk be 
M2, . . . , Mfc-i in order. Call the point Ui of a chord {ui,Uj) for i < j as the origin of the chord 
and Uj the end of the chord. Now start walking from Ui to Uk along the tree path, outputting 
tree edges till the origin of a chord is encountered. Output the chord and move on to the 
end of the chord and repeat. It is easy to see that the edges output by this procedure along 
with the non-tree edge {ui,Uk) form an induced cycle because either the origin or endpoint 
of any other chord of C(e) is not on this cycle. Also, because the endpoints of all edges on 
this cycle are oppositely colored except for {ui,Uk), this is an odd cycle. 
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At this point we have a cycle C in G with a non-bipartite conflict graph Hc{G') and an 
induced odd cycle C in Hc{G') witnessing this. Now we prove the following, 

Lemma 7. Given an induced odd cycle C in Hc{G'), we can, in logspace, find a Kuratowski 
subgraph. 

Proof. First, suppose that two conflicting bridges Bi and B2 in the odd cycle share 3 points 
of attachment ai, 02 and 03. If either of the bridges( Bi say.) has another point of attachment 
04 then, clearly the points of attachment ai, 03 of B2 alternate with the points of attachment 
02,04 of Bi. Therefore, it is sufficient to deal with the case when the case where both Bi 
and B2 have just 3 points of attachment. In this case it is not difficult to see that any bridge 
that conflicts with Bi also conflicts with B2 and vice-versa. Hence C must be a 3-cycle. We 
deal with this case in lemma [HI 

Next, consider the case where C is an odd cycle of size greater than 3 and the conflict of 
a bridge B in the odd cycle with any other bridge in the odd-cycle is witnessed by 2 points 
of attachment of B i.e we exclude the possibility that 2 bridges share 3 points of attachment. 

It is easy to see that 3 2 points of attachment for every bridge that witness both it's 
conflicts. Thus by contracting all bridges (excluding points of attachment) to single points 
and removing edges of attachment, one can reduce all bridges to paths while maintaining all 
conflicts. This can be done in logspace since for each bridge one only needs to remember the 
witnesses of conflict of the bridge with its neighbours (in C').(atmost 8 points.) 

If we label the vertices of C as vbo,vbi, ■ ■ ■ ^t^Bik > 1) ^^r some positive integer A;, and 
the points of attachment of bridge Bi as Ui^Vi then the points occur along G in the order: 

Mo, V2k, Ui,Vo, U2, f 1, . . . , U2k^l, V2k~2, M2fc, V2k-1- 



7 8 




3 2 



Fig. 1. In the figure, we have a cycle with the 9-cycle as it's conflict graph . On treating 
{6, 8, 10} as a single point and leaving out the edges (6, 7), (7, 8), (8, 9) and (9, 10), we obtain 
a subdivision of i^s 
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Now, consider the cycle U2k, Uo, ^ 2fe, i^o, U' (Where U' — {{vi, U3}[JB^[j{vs}Li. . .U{u2fc-i}) 
along with the bridges , Bq the paths connecting uq and U' , V2k and U' and the path 
{^0, U2} U B2 . . . {v2k-2, U2k} Clearly, this is a minor, (see Fig.l for an example.) 

Finally we are left with the following case: 

Lemma 8. Given a cycle in G' with three mutually conflicting bridges, it is possible to 
eoctract a Kuratowski minor of G' in logspace. 

Proof. Clearly, it is sufficient to consider 4 points of attachment for each bridge since 4 points 
of attachment suffice to witness conflict with two other bridges. We can contract the bridges 
(excluding the points of attachment) to single points and reduce the problem of finding a 
Kuratowski subgraph in the above graph to that of finding a Kuratowski minor in a non- 
planar graph with atmost 15 vertices and 24 edges. Since this is a constant sized graph we 
can find a Kuratowski minor by brute-force. 
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